cssnode: Add setters/getters for name
authorBenjamin Otte <otte@redhat.com>
Sat, 5 Sep 2015 04:31:32 +0000 (06:31 +0200)
committerBenjamin Otte <otte@redhat.com>
Thu, 22 Oct 2015 14:35:14 +0000 (16:35 +0200)
gtk/gtkcssnode.c
gtk/gtkcssnodeprivate.h

index 660315550f8a494f5000321191c3ae97653a0036..8559a59b9e9a241f0031ba34b7d65b8646843cb0 100644 (file)
@@ -43,6 +43,7 @@ enum {
   PROP_0,
   PROP_CLASSES,
   PROP_ID,
+  PROP_NAME,
   PROP_STATE,
   PROP_VISIBLE,
   PROP_WIDGET_TYPE,
@@ -104,6 +105,10 @@ gtk_css_node_get_property (GObject    *object,
       g_value_set_string (value, gtk_css_node_get_id (cssnode));
       break;
 
+    case PROP_NAME:
+      g_value_set_string (value, gtk_css_node_get_name (cssnode));
+      break;
+
     case PROP_STATE:
       g_value_set_flags (value, gtk_css_node_get_state (cssnode));
       break;
@@ -139,6 +144,10 @@ gtk_css_node_set_property (GObject      *object,
       gtk_css_node_set_id (cssnode, g_value_get_string (value));
       break;
 
+    case PROP_NAME:
+      gtk_css_node_set_name (cssnode, g_value_get_string (value));
+      break;
+
     case PROP_STATE:
       gtk_css_node_set_state (cssnode, g_value_get_flags (value));
       break;
@@ -589,6 +598,12 @@ gtk_css_node_class_init (GtkCssNodeClass *klass)
                          NULL,
                          G_PARAM_READWRITE
                          | G_PARAM_EXPLICIT_NOTIFY | G_PARAM_STATIC_STRINGS);
+  cssnode_properties[PROP_NAME] =
+    g_param_spec_string ("name", "Name",
+                         "Name identifying the type of node",
+                         NULL,
+                         G_PARAM_READWRITE
+                         | G_PARAM_EXPLICIT_NOTIFY | G_PARAM_STATIC_STRINGS);
   cssnode_properties[PROP_STATE] =
     g_param_spec_flags ("state", "State",
                         "State flags",
@@ -994,6 +1009,24 @@ gtk_css_node_get_visible (GtkCssNode *cssnode)
   return cssnode->visible;
 }
 
+void
+gtk_css_node_set_name (GtkCssNode              *cssnode,
+                       /*interned*/ const char *name)
+{
+  if (gtk_css_node_declaration_set_name (&cssnode->decl, name))
+    {
+      gtk_css_node_invalidate (cssnode, GTK_CSS_CHANGE_NAME);
+      g_object_notify_by_pspec (G_OBJECT (cssnode), cssnode_properties[PROP_NAME]);
+      g_object_notify_by_pspec (G_OBJECT (cssnode), cssnode_properties[PROP_WIDGET_TYPE]);
+    }
+}
+
+/* interned */ const char *
+gtk_css_node_get_name (GtkCssNode *cssnode)
+{
+  return gtk_css_node_declaration_get_name (cssnode->decl);
+}
+
 void
 gtk_css_node_set_widget_type (GtkCssNode *cssnode,
                               GType       widget_type)
@@ -1001,6 +1034,7 @@ gtk_css_node_set_widget_type (GtkCssNode *cssnode,
   if (gtk_css_node_declaration_set_type (&cssnode->decl, widget_type))
     {
       gtk_css_node_invalidate (cssnode, GTK_CSS_CHANGE_NAME);
+      g_object_notify_by_pspec (G_OBJECT (cssnode), cssnode_properties[PROP_NAME]);
       g_object_notify_by_pspec (G_OBJECT (cssnode), cssnode_properties[PROP_WIDGET_TYPE]);
     }
 }
index 9f1dc42b4f2e387df446d4c66f04e1b32365014c..7792647f774857859b988442ccdd1af9ce65efab 100644 (file)
@@ -113,6 +113,9 @@ void                    gtk_css_node_set_visible        (GtkCssNode            *
                                                          gboolean               visible);
 gboolean                gtk_css_node_get_visible        (GtkCssNode            *cssnode);
 
+void                    gtk_css_node_set_name           (GtkCssNode            *cssnode,
+                                                         /*interned*/const char*name);
+/*interned*/const char *gtk_css_node_get_name           (GtkCssNode            *cssnode);
 void                    gtk_css_node_set_widget_type    (GtkCssNode            *cssnode,
                                                          GType                  widget_type);
 GType                   gtk_css_node_get_widget_type    (GtkCssNode            *cssnode);